安装 easywebpack-cli 工具

npm install easywebpack-cli -g

添加 ${app_root}/.babelrc 文件

具体根据实际情况添加相关 babel 插件配置,以下仅仅是举例. 详细配置见:https://easy-team.gitee.io/easywebpack/babel

  • babel 7 配置
{
  "presets": [
    "@babel/preset-react",
    [
      "@babel/preset-env",
      {
        "modules": false
      }
    ]
  ],
  "plugins": [
    "@babel/plugin-syntax-dynamic-import",
    "@babel/plugin-proposal-object-rest-spread", 
  ]
}
  • babel 6 配置
{
  "presets": ['react',["env",{ "modules": false }]],
  "plugins": [
    "transform-object-rest-spread",
    "syntax-dynamic-import"
  ],
  "comments": false
}

添加 ${app_root}/postcss.config.js 文件

具体根据实际情况添加 postcss 配置,以下仅仅是举例:

'use strict';
module.exports = {
  plugins: [
    require('autoprefixer')
  ]
};

HTML 页面 HTMLWebpackPlugin 模板配置

默认 template 路径文件为 src/view/layout.html 如果需要构建 HTML 文件,直接存在该文件即可,无需 Webpack 配置。

<!DOCTYPE html>
<html lang="en">
<head>
  <title></title>
  <meta http-equiv="content-type" content="text/html;charset=utf-8">
  <meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, minimal-ui">
  <link rel="shortcut icon" href="/favicon.ico" type="image/x-icon" />
</head>
<body>
  <div id="app"></div>
</body>
</html>

配置编写

easywebpack-react 项目构建解决方案,支持前端和SSR模式构建。默认 HtmlWebpackPlugin 的 template 路径为 src/view/layout.html

Webpack 原生配置

  • 前端渲染模式构建

快速获取 react Webpack 构建配置

const easywebpack = require('@easy-team/easywebpack-react');
const webpackConfig = easywebpack.getWebpackConfig({
    target: 'web',
    entry:{
      app: 'src/index.js'
    }
});
  • SSR 渲染模式构建

快速获取 React SSR 模式 Webpack 构建配置

const easywebpack = require('@easy-team/easywebpack-react');
// 返回的是两个 webpack 配置
const webpackConfigList = easywebpack.getWebpackConfig({
    entry:{
      index: 'src/index.js'
    }
});

基于 easywebpack-react 编写 Webpack 配置

配置编写
// webpack.config.js
const easywebpack = require('@easy-team/easywebpack-react');
const { webpack, merge } = easywebpack.webpack;
const env = process.env.BUILD_ENV;
const baseWebpackConfig = easywebpack.getWebpackConfig({
    env, // 根据环境变量生成对应配置,可以在 npm script 里面配置,支持 dev, test, prod 模式
    target : 'web', // target: web 表示只获取前端构建 Webpack 配置
    entry:{
      index: 'src/index.js'
    }
});

// 拿到基础配置, 可以进行二次加工
const webpackConfig = merge(baseWebpackConfig, { 
  // 自定义配置
})

module.exports = webpackConfig;
本地开发
  • 使用 webpack-dev-server : webpack-dev-server --hot
  • 使用 easywepback-cli: easy dev --webpack

打包编译
  • 使用 webpack-cli : webpack --mode production --config webpack.config.js
  • 使用 easywepback-cli: easy build --webpack

基于 easywebpack-cli 构建模式

全局安装 easywebpack-cli 插件
npm i easywebpack-cli  -g

安装成功以后, 就可以在命令行中使用 easyeasywebpack 命令, 比如 easy build, easy server, easy print

添加 webpack.config.js 配置

在项目根目录添加 webpack.config.js 文件, 添加如下配置

const path = require('path');
module.exports = {
  target:'web', 
  framework: 'react', // 指定用 easywebpack-react 解决方案, 请在项目中安装该依赖
  entry: {
    index: 'src/index.js'
  }
};
编译文件
easy build dev

easy build test

easy build prod
直接运行
easy dev

# 构建文件并启动本地静态 HTTP Server
easy build --server

运行完成自动打开编译结果页面 : http://127.0.0.1:8888/debug

前端项目初始化

  • 全局安装 easywebpack-cli 插件
npm i easywebpack-cli  -g
  • 请通过 easy init 命令初始化骨架项目, 根据提示选择对应的项目类型即可.

AntD 按需加载

依赖配置

// ${root}/package.json
{
 "devDependencies": {
   "babel-plugin-import": "^1.0.0"
 }
}

代码编写

import { Button } from 'antd';

.babelrc 配置

{
    "presets": [
    "@babel/preset-react",
    [
      "@babel/preset-env",
      {
        "modules": false
      }
    ]
  ],
  "plugins": [
    "@babel/plugin-syntax-dynamic-import",
    "@babel/plugin-proposal-object-rest-spread", 
    ["import", {
        "libraryName": "antd",
        "libraryDirectory": "lib",
        "style": true
      }]
   ],
   "env": {
    "development": {
      "plugins": [
        "react-hot-loader/babel"
      ]
    }
  },
}

AntD 主题定制

  • AntD 主题定制需要开启 webpack less 编译
  • Babel 和 Less 编译需要包含 node_modules 的 antd

less 构建支持

// ${root}/webpack.config.js
module.exports = {
  module:{
    rules:[
      { less: true }
    ]
  }
}

依赖配置

// ${root}/package.json
{
 "devDependencies": {
   "less": "^2.7.2",
   "less-loader": "^4.1.0"
 }
}

构建配置

//${root}/webpack.config.js
const path = require('path');
const resolve = (filepath) => path.resolve(__dirname, filepath);
module.exports = {
  loaders: {
    babel: {
      include: [resolve('app/web'), resolve('node_modules')]
    },
    less: {
      include: [resolve('app/web'), resolve('node_modules')],
      options: {
        javascriptEnabled: true,
        modifyVars: {
          'primary-color': 'red',
          'link-color': '#1DA57A',
          'border-radius-base': '2px'
        }
      }
    }
  }
};

Sass/Less/Stylus 配置

https://easy-team.gitee.io/easywebpack/css

热更新实现

https://easy-team.gitee.io/easywebpack/hot


Author: sky
Reprint policy: All articles in this blog are used except for special statements CC BY 4.0 reprint polocy. If reproduced, please indicate source sky !
 Previous
构建速度 构建速度
检测构建速度最新的 easywebpack-cli@4.0.0 可以通过 easy build --speed 检测 Webpack 各 loader 和 plugin 处理耗时。DLL 公共提取Webpack 通过 DLLPlugin 和 DLLReferencePlugin 可以实现公共类库的单独提取,能极大大提升了构建的速度.只需要在 webpack.config.js 文件添加 dll 节点配置即可完成 dll 整个流程。module.exports = { dll:['vue...
2019-11-10 sky
Next 
域名代理 域名代理
本地开发域名代理构建支持前提:代理域名能够映射到本机ip地址的功能需要你自己在电脑上面配置。如果是实际的存在的域名,理论上面就不需要自己配置域名映射。该功能只在 Egg 应用构建本地开发使用。在 Egg SSR 应用开发时,Egg 应用的访问地址, 静态资源构建的地址, HMR 地址都是 ip...
2019-11-10 sky